gadget: Add a get_render_node vfunc
authorMatthias Clasen <mclasen@redhat.com>
Fri, 28 Oct 2016 16:55:33 +0000 (12:55 -0400)
committerMatthias Clasen <mclasen@redhat.com>
Tue, 1 Nov 2016 18:29:25 +0000 (14:29 -0400)
This will let us do box gadgets like we do containers.

gtk/gtkcssgadget.c
gtk/gtkcssgadgetprivate.h

index dbce0c94d7f20cde307a9a364e0aad95e894f50a..1559fac1a0bf1fd4a458191631d6c535cb8aa5f7 100644 (file)
@@ -261,6 +261,10 @@ gtk_css_gadget_has_content (GtkCssGadget *gadget)
   return gadget_class->draw != gtk_css_gadget_real_draw;
 }
 
+static GskRenderNode * gtk_css_gadget_real_get_render_node (GtkCssGadget  *gadget,
+                                                            GskRenderer   *renderer,
+                                                            gboolean       draw_focus);
+
 static void
 gtk_css_gadget_class_init (GtkCssGadgetClass *klass)
 {
@@ -273,6 +277,7 @@ gtk_css_gadget_class_init (GtkCssGadgetClass *klass)
   klass->get_preferred_size = gtk_css_gadget_real_get_preferred_size;
   klass->allocate = gtk_css_gadget_real_allocate;
   klass->draw = gtk_css_gadget_real_draw;
+  klass->get_render_node = gtk_css_gadget_real_get_render_node;
   klass->style_changed = gtk_css_gadget_real_style_changed;
   klass->has_content = gtk_css_gadget_has_content;
 
@@ -812,10 +817,10 @@ gtk_css_gadget_allocate (GtkCssGadget        *gadget,
   priv->clip = *out_clip;
 }
 
-GskRenderNode *
-gtk_css_gadget_get_render_node (GtkCssGadget  *gadget,
-                                GskRenderer   *renderer,
-                                gboolean       draw_focus)
+static GskRenderNode *
+gtk_css_gadget_real_get_render_node (GtkCssGadget  *gadget,
+                                     GskRenderer   *renderer,
+                                     gboolean       draw_focus)
 {
   GtkCssGadgetPrivate *priv = gtk_css_gadget_get_instance_private (gadget);
   GtkBorder clip, margin, border, padding;
@@ -1112,6 +1117,14 @@ gtk_css_gadget_draw (GtkCssGadget *gadget,
 #endif
 }
 
+GskRenderNode *
+gtk_css_gadget_get_render_node (GtkCssGadget  *gadget,
+                                GskRenderer   *renderer,
+                                gboolean       draw_focus)
+{
+   return GTK_CSS_GADGET_GET_CLASS (gadget)->get_render_node (gadget, renderer, draw_focus);
+}
+
 void
 gtk_css_gadget_queue_resize (GtkCssGadget *gadget)
 {
index 54c6132551728e20a856626e755ec088c4dd5f6c..347920d0ad5e6aecaef3d1cbde3f5d609e951737 100644 (file)
@@ -68,6 +68,10 @@ struct _GtkCssGadgetClass
                                                          int                     width,
                                                          int                     height);
 
+  GskRenderNode * (* get_render_node)                   (GtkCssGadget           *gadget,
+                                                         GskRenderer            *renderer,
+                                                         gboolean                draw_focus);
+
   void          (* style_changed)                       (GtkCssGadget           *gadget,
                                                          GtkCssStyleChange      *change);